<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <script>
        // eval--------------------------------
        // let不行 var可以
        function foo(str, a) {
            eval(str) // 原本作用域只有1，但是现在多了b，var b = 3也被执行了
            console.log(a, b);
        }
        var b = 2
        foo('var b = 3', 1)

        function foo2(fn) {
            eval(fn)
            console.log(sing);
        }
        foo2('function sing() {}')

        // function foo3(str, a) {
        //     "use strict"
        //     eval(str) // 原本作用域只有1，但是现在多了b，var b = 3也被执行了
        //     console.log(a, c);
        // }
        // foo3('var c = 3', 1)

        // setTimeout--------------------------------
        setTimeout('console.log(100)', 1000) // 100

        // new Function--------------------------------
        let foo4 = new Function('a,b', 'console.log(`new Function`)')
        console.log(foo4);

    </script>
</body>

</html>